import { fileURLToPath, URL } from 'node:url';

import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
import AutoImport from 'unplugin-auto-import/vite';
import Components from 'unplugin-vue-components/vite';
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers';

// https://vitejs.dev/config/
export default defineConfig({
  base: '',
  plugins: [
    vue(),
    AutoImport({
      // 库
      imports: ['vue', 'vue-router', 'pinia', '@vueuse/core'],
      // 手动创建的方法
      dirs: ['src/hook', 'src/service', 'src/stores'],
      // 开启提示
      dts: true,
      resolvers: [ElementPlusResolver()]
    }),
    Components({
      // 组件文件夹
      dirs: ['src/components'],
      // 开启提示
      dts: true,
      resolvers: [ElementPlusResolver()]
    })
  ],
  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url))
    }
  }
});
